﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using FlorDeLiz.BusinessEntitites;
using FlorDeLiz.DataAccess;
using FlorDeLiz.LogException;
using System.Reflection;

namespace FlorDeLiz.BusinessLayer
{
    public class ClienteBL
    {
        #region Singleton
        private static ClienteBL instancia;
        public static ClienteBL Instancia
        {
            get
            {
                if (instancia == null)
                {
                    instancia = new ClienteBL();
                }
                return instancia;
            }
        }
        #endregion

        public List<Cliente> ObterClientes(int? id, string nome, string cpf_Cnpj)
        {
            try
            {                
                return ClienteDA.Instancia.ObterClientes(id, nome, cpf_Cnpj);
            }
            catch(Exception ex)
            {
                LogService.GravarLog(Log.Instancia.Loggin(DateTime.Now,
                                             ex.Message,
                                             MethodBase.GetCurrentMethod().DeclaringType.Name,
                                             MethodBase.GetCurrentMethod().Name,
                                             ex.StackTrace));
                return null;
            }
        }

        public Cliente GravarCliente(Cliente cliente)
        {           
            try
            {
                if (cliente.Id == 0)
                {
                    cliente = ClienteDA.Instancia.InserirCliente(cliente);
                }
                else
                {
                    cliente = ClienteDA.Instancia.AlterarCliente(cliente);
                }
                return cliente;
            }
            catch (Exception ex)
            {
                LogService.GravarLog(Log.Instancia.Loggin(DateTime.Now,
                                             ex.Message,
                                             MethodBase.GetCurrentMethod().DeclaringType.Name,
                                             MethodBase.GetCurrentMethod().Name,
                                             ex.StackTrace));
                cliente.OcorreuErro = true;
                cliente.Mensagem = "Falha ao Gravar Cliente!";
                return cliente;
            }
        }
    }
}
